home *** CD-ROM | disk | FTP | other *** search
/ Aminet 16 / Aminet 16 (1996)(GTI - Schatztruhe)[!][Dec 1996].iso / Aminet / comm / term / term_source.lha / Extras / Source / term-source.lha / About.c next >
C/C++ Source or Header  |  1996-10-20  |  18KB  |  829 lines

  1. /*
  2. **    About.c
  3. **
  4. **    Support routines for the `About' window.
  5. **
  6. **    Copyright © 1990-1996 by Olaf `Olsen' Barthel
  7. **        All Rights Reserved
  8. **
  9. **    :ts=4
  10. */
  11.  
  12. #ifndef _GLOBAL_H
  13. #include "Global.h"
  14. #endif
  15.  
  16. #define HEADING 4
  17.  
  18. enum    {    GAD_FRAME=1000,GAD_SCROLL,GAD_BUTTON };
  19.  
  20.     /* LocalDeleteBitMap(struct BitMap *BitMap,LONG Width,LONG Height):
  21.      *
  22.      *    Delete yet another screen bitmap.
  23.      */
  24.  
  25. STATIC VOID
  26. LocalDeleteBitMap(struct BitMap *BitMap,LONG Width,LONG Height)
  27. {
  28.     if(BitMap)
  29.     {
  30.         LONG i;
  31.  
  32.         WaitBlit();
  33.  
  34.         for(i = 0 ; i < BitMap->Depth ; i++)
  35.         {
  36.             if(BitMap->Planes[i])
  37.                 FreeRaster(BitMap->Planes[i],Width,Height);
  38.         }
  39.  
  40.         FreeVecPooled(BitMap);
  41.     }
  42. }
  43.  
  44.     /* LocalCreateBitMap(LONG Depth,LONG Width,LONG Height):
  45.      *
  46.      *    Create yet another screen bitmap.
  47.      */
  48.  
  49. STATIC struct BitMap *
  50. LocalCreateBitMap(LONG Depth,LONG Width,LONG Height)
  51. {
  52.     struct BitMap *BitMap;
  53.  
  54.     if(BitMap = (struct BitMap *)AllocVecPooled(sizeof(struct BitMap),MEMF_ANY))
  55.     {
  56.         BOOL    Success = TRUE;
  57.         LONG    i;
  58.  
  59.         InitBitMap(BitMap,Depth,Width,Height);
  60.  
  61.         for(i = 0 ; Success && i < Depth ; i++)
  62.         {
  63.             if(!(BitMap->Planes[i] = AllocRaster(Width,Height)))
  64.                 Success = FALSE;
  65.         }
  66.  
  67.         if(Success)
  68.             return(BitMap);
  69.  
  70.         LocalDeleteBitMap(BitMap,Width,Height);
  71.     }
  72.  
  73.     return(NULL);
  74. }
  75.  
  76.     /* CreateBitMapFromImage(struct Image *Image,struct BitMap *BitMap):
  77.      *
  78.      *    Turn an Intuition Image into a Gfx BitMap.
  79.      */
  80.  
  81. STATIC VOID
  82. CreateBitMapFromImage(struct Image *Image,struct BitMap *BitMap)
  83. {
  84.     PLANEPTR    Data    = (PLANEPTR)Image->ImageData;
  85.     ULONG        Modulo    = ((((ULONG)Image->Width) + 15) >> 3) & ~1;
  86.     LONG        i;
  87.  
  88.     InitBitMap(BitMap,Image->Depth,Image->Width,Image->Height);
  89.  
  90.     for(i = 0 ; i < Image->Depth ; i++, Data += Modulo * Image->Height)
  91.         BitMap->Planes[i] = Data;
  92. }
  93.  
  94.     /* RecolourBitMap():
  95.      *
  96.      *    Remap a BitMap to use a different colour selection.
  97.      */
  98.  
  99. STATIC struct BitMap *
  100. RecolourBitMap (struct BitMap *Src, UBYTE * Mapping, UBYTE DestDepth, LONG Width, LONG Height)
  101. {
  102.     struct BitMap *Dst;
  103.  
  104.         /* Create the bitmap to hold the remapped data. */
  105.  
  106.     if(Dst = LocalCreateBitMap(DestDepth,Width,Height))
  107.     {
  108.         struct BitMap *SingleMap;
  109.  
  110.             /* Create a single bitplane bitmap. */
  111.  
  112.         if(SingleMap = LocalCreateBitMap(1,Width,Height))
  113.         {
  114.             struct BitMap *FullMap;
  115.  
  116.                 /* Create a dummy bitmap. */
  117.  
  118.             if(FullMap = (struct BitMap *)AllocVecPooled(sizeof(struct BitMap),MEMF_ANY))
  119.             {
  120.                 LONG i,Mask = (1L << Src->Depth) - 1;
  121.  
  122.                     /* Make the dummy bitmap use the
  123.                      * single bitmap in all planes.
  124.                      */
  125.  
  126.                 InitBitMap(FullMap,DestDepth,Width,Height);
  127.  
  128.                 for(i = 0 ; i < DestDepth ; i++)
  129.                     FullMap->Planes[i] = SingleMap->Planes[0];
  130.  
  131.                     /* Clear the destination bitmap. */
  132.  
  133.                 BltBitMap(Dst,0,0,Dst,0,0,Width,Height,MINTERM_ZERO,0xFF,NULL);
  134.  
  135.                     /* Is colour zero to be mapped to a non-zero colour? */
  136.  
  137.                 if(Mapping[0])
  138.                 {
  139.                         /* Clear the single plane bitmap. */
  140.  
  141.                     BltBitMap(SingleMap,0,0,SingleMap,0,0,Width,Height,MINTERM_ZERO,1,NULL);
  142.  
  143.                         /* Merge all source bitplane data. */
  144.  
  145.                     BltBitMap(Src,0,0,FullMap,0,0,Width,Height,MINTERM_B_OR_C,Mask,NULL);
  146.  
  147.                         /* Invert the single plane bitmap, to give us
  148.                          * the zero colour bitmap we can work with.
  149.                          */
  150.  
  151.                     BltBitMap(SingleMap,0,0,SingleMap,0,0,Width,Height,MINTERM_NOT_C,1,NULL);
  152.  
  153.                         /* Now set all the bits for colour zero. */
  154.  
  155.                     BltBitMap(FullMap,0,0,Dst,0,0,Width,Height,MINTERM_B_OR_C,Mapping[0],NULL);
  156.                 }
  157.  
  158.                     /* Run down the colours. */
  159.  
  160.                 for(i = 1 ; i <= Mask ; i++)
  161.                 {
  162.                         /* Set the single plane bitmap to all 1's. */
  163.  
  164.                     BltBitMap(SingleMap,0,0,SingleMap,0,0,Width,Height,MINTERM_ONE,1,NULL);
  165.  
  166.                         /* Isolate the pixels to match the colour
  167.                          * specified in `i'.
  168.                          */
  169.  
  170.                     BltBitMap(Src,0,0,FullMap,0,0,Width,Height,MINTERM_B_AND_C,i,NULL);
  171.  
  172.                     if(Mask ^ i)
  173.                         BltBitMap(Src,0,0,FullMap,0,0,Width,Height,MINTERM_NOT_B_AND_C,Mask ^ i,NULL);
  174.  
  175.                         /* Set the pixels in the destination bitmap,
  176.                          * use the designated colour.
  177.                          */
  178.  
  179.                     BltBitMap(FullMap,0,0,Dst,0,0,Width,Height,MINTERM_B_OR_C,Mapping[i],NULL);
  180.                 }
  181.  
  182.                     /* Free the temporary bitmap. */
  183.  
  184.                 FreeVecPooled(FullMap);
  185.  
  186.                     /* Free the single plane bitmap. */
  187.  
  188.                 LocalDeleteBitMap(SingleMap,Width,Height);
  189.  
  190.                     /* Return the result. */
  191.  
  192.                 return(Dst);
  193.             }
  194.  
  195.             LocalDeleteBitMap(SingleMap,Width,Height);
  196.         }
  197.  
  198.         LocalDeleteBitMap(Dst,Width,Height);
  199.     }
  200.  
  201.     return(NULL);
  202. }
  203.  
  204. STATIC STRPTR Table[] =
  205. {
  206.     "\bBeta testing:",
  207.     "",
  208.     "Göran Åberg   Peter L. Banville Jr.",
  209.     "Stefan Becker   Abdelkader Benbachir",
  210.     "Sebastian Bergmann   Martin Berndt",
  211.     "Gregory A. Chance   Keith Christopher",
  212.     "Mark Constable   Steve Corder",
  213.     "Sebastian Delmont   Marcel Döring",
  214.     "Klaus Dürr   Frank Dürring",
  215.     "Bernd Ernesti   Kenneth Fribert",
  216.     "Kay Gehrke   Jay Grizzard",
  217.     "Stefan Gybas   Christoph Gülicher",
  218.     "Chris Hanson   Peer Hasselmeyer",
  219.     "Christian Hechelmann   Holger Heinrich",
  220.     "Rodney Hester   Florian Hinzmann",
  221.     "Hung-Tung Hsu   Stefan Hudson",
  222.     "Kai Iske   Piotr Kaminski",
  223.     "Jari Karjalainen   Andreas M. Kirchwitz",
  224.     "Tony Kirkland   Stellan Klebom",
  225.     "Simo Koivukoski   Jens Langner",
  226.     "Russell John LeBar   Jason C. Leach",
  227.     "Michael Leun   Holger Lubitz",
  228.     "Daniel M. Makovec   Bob Maple",
  229.     "Julian Matthew   Chris Mattingly",
  230.     "Matthias Merkel   Dabe Murphy",
  231.     "William Michael Mushkin   Christopher G. Newby",
  232.     "Dean S. Pemberton   Yves Perrenoud",
  233.     "Olaf Peters   Sven Reger",
  234.     "Robert Reiswig   Matti Rintala",
  235.     "Alfredo Rojas   Karsten Rother",
  236.     "Ottmar Röhrig   Matthias Scheler",
  237.     "Markus Schmall   Robert L. Shady",
  238.     "Leon D. Shaner   Eric W. Sommer",
  239.     "Jason Soukeras   Gary B. Standen",
  240.     "Keith A. Stewart   Joel E. Swan",
  241.     "Jonathan Tew   Bodo Thevissen",
  242.     "Alexander Wild   Jürgen Zeschky",
  243.     "Michael Zielesny",
  244.     "",
  245.     "\bForeign language translations:",
  246.     "",
  247.     "Olaf Barthel (Deutsch)",
  248.     "Phillippe Brand (Français)",
  249.     "Thomas Egrelius (Svenska)",
  250.     "Flemming Lindeblad (Dansk)",
  251.     "Andrea Suatoni (Italiano)",
  252.     "Edmund Vermeulen (Nederlands)",
  253.     "«Sorry, I lost your name» (Español)",
  254.     "",
  255.     "\bDocumentation:",
  256.     "",
  257.     "Olaf Barthel   Garry Glendown",
  258.     "Henning Hucke   Mike Safer",
  259.     "Mark Schröer",
  260.     "",
  261.     "\bXPR Libraries by:",
  262.     "",
  263.     "Marc Boucher (xmodem)",
  264.     "Terence Finney (bplus)",
  265.     "Rick Huebner & William M. Perkins (zmodem)",
  266.     "Ueli Kaufmann (ascii, ymodem, vms)",
  267.     "Marco Papa & Stephen Walton (kermit)",
  268.     "Jack Rouse (quickb)",
  269.     "",
  270.     "\bXEM Libraries by:",
  271.     "",
  272.     "Ueli Kaufmann (amiga, ascii, bbs, vt340)",
  273.     "Stef Rave (rip)",
  274.     "",
  275.     "\bPeople who will deny that",
  276.     "\bthey were ever involved:",
  277.     "",
  278.     "John Burton   Peter Fischer",
  279.     "David Göhler   Michael-Wolfgang Hohmann",
  280.     "David Jones   Marko Küchmann",
  281.     "Bernd Lambracht   Roby Leeman & AUGS",
  282.     "Frank Mariak   Germar Morgenthaler",
  283.     "Jürgen Otte   Till `Dill-Prince' Prinzler",
  284.     "Nicola Salmoria   Ralph Schmidt",
  285.     "Veith Schörgenhummer   Thorsten Seidel",
  286.     "Markus Stoll   Martin Taillefer",
  287.     "Christoph Teuber   Ralf Thanner",
  288.     "Volker Ulle & the Aquila Sysop Team   Michael Vaeth",
  289.     "Oliver Wagner   Christopher Wichura",
  290.     "Udo Wolt   Matthias Zepf",
  291.     "",
  292.     "\aDon't switch off, it's almost over!",
  293.     "",
  294.     NULL
  295. };
  296.  
  297. STATIC VOID
  298. PrintThisLine(struct RastPort *RPort,struct Rectangle *Clip,LONG Top,STRPTR Line)
  299. {
  300.     LONG Len,Width;
  301.  
  302.     Len = strlen(Line);
  303.  
  304.     if(*Line == '\b' || *Line == '\a')
  305.     {
  306.         ULONG Style;
  307.  
  308.         if(*Line == '\b')
  309.             Style = FSF_BOLD;
  310.         else
  311.             Style = FSF_ITALIC;
  312.  
  313.         SetSoftStyle(RPort,Style,FSF_BOLD | FSF_ITALIC);
  314.         Line++;
  315.         Len--;
  316.     }
  317.     else
  318.         SetSoftStyle(RPort,0,FSF_BOLD | FSF_ITALIC);
  319.  
  320.     if(Len > 0)
  321.     {
  322.         Width = TextLength(RPort,Line,Len);
  323.  
  324.         PlaceText(RPort,Clip->MinX + (Clip->MaxX - Clip->MinX + 1 - Width) / 2,Top,Line,Len);
  325.     }
  326. }
  327.  
  328.  
  329.     /* ShowAbout():
  330.      *
  331.      *    Open a window, draw the `term' logo, show some text
  332.      *    and wait for user reaction.
  333.      */
  334.  
  335. BOOL
  336. ShowAbout(LONG Ticks)
  337. {
  338.     struct BitMap        *ImageBitMap = NULL;
  339.     LONG                 ImageWidth,
  340.                          ImageHeight;
  341.     struct LayoutHandle    *Handle;
  342.     BOOL                 GotRexxMessage = FALSE;
  343.  
  344.     if(IconBase)
  345.     {
  346.         struct DiskObject *Icon;
  347.  
  348.         if(Icon = GetProgramIcon())
  349.         {
  350.             STATIC UWORD DefaultColours[4] =
  351.             {
  352.                 0xAAA,
  353.                 0x000,
  354.                 0xFFF,
  355.                 0x68B
  356.             };
  357.  
  358.             UBYTE    Mapping[4];
  359.             LONG    Colour1,Colour2;
  360.             LONG    ChannelDistance;
  361.             LONG    Distance,BestDistance,BestIndex,Depth,Count,i,j;
  362.             BOOL    Duplicates = FALSE;
  363.  
  364.             Depth = GetBitMapDepth(Window->RPort->BitMap);
  365.             Count = Window->WScreen->ViewPort.ColorMap->Count;
  366.  
  367.             if(Depth > 8)
  368.                 Depth = 8;
  369.  
  370.             if(Count > (1L << Depth))
  371.                 Count = 1L << Depth;
  372.  
  373.             if(Count > 256)
  374.                 Count = 256;
  375.  
  376.             if(Count >= 4)
  377.             {
  378.                 for(i = 0 ; i < 4 ; i++)
  379.                 {
  380.                     Colour2 = DefaultColours[i];
  381.  
  382.                     BestDistance    = 3 * 15 * 15;
  383.                     BestIndex        = 0;
  384.  
  385.                     for(j = 0 ; j < Count ; j++)
  386.                     {
  387.                         Colour1 = GetRGB4(Window->WScreen->ViewPort.ColorMap,j);
  388.  
  389.                         ChannelDistance = ((LONG)((Colour1 >> 8) & 0xF)) - ((LONG)((Colour2 >> 8) & 0xF));
  390.  
  391.                         Distance = ChannelDistance * ChannelDistance;
  392.  
  393.                         ChannelDistance = ((LONG)((Colour1 >> 4) & 0xF)) - ((LONG)((Colour2 >> 4) & 0xF));
  394.  
  395.                         Distance += ChannelDistance * ChannelDistance;
  396.  
  397.                         ChannelDistance = ((LONG)(Colour1 & 0xF)) - ((LONG)(Colour2 & 0xF));
  398.  
  399.                         Distance += ChannelDistance * ChannelDistance;
  400.  
  401.                         if(Distance < BestDistance)
  402.                         {
  403.                             BestDistance    = Distance;
  404.                             BestIndex        = j;
  405.                         }
  406.                     }
  407.  
  408.                     Mapping[i] = BestIndex;
  409.                 }
  410.  
  411.                 for(i = 0 ; !Duplicates && i < 4 ; i++)
  412.                 {
  413.                     for(j = i + 1 ; !Duplicates && j < 4 ; j++)
  414.                         Duplicates = (Mapping[i] == Mapping[j]);
  415.                 }
  416.  
  417.                 if(!Duplicates)
  418.                 {
  419.                     struct BitMap     LocalBitMap;
  420.                     struct Image    *Image;
  421.  
  422.                     Image = Icon->do_Gadget.GadgetRender;
  423.  
  424.                     if(Image->Depth == 2)
  425.                     {
  426.                         CreateBitMapFromImage(Image,&LocalBitMap);
  427.  
  428.                         if(ImageBitMap = RecolourBitMap(&LocalBitMap,Mapping,Depth,Image->Width,Image->Height))
  429.                         {
  430.                             ImageWidth    = Image->Width;
  431.                             ImageHeight    = Image->Height;
  432.                         }
  433.                     }
  434.                 }
  435.             }
  436.  
  437.             FreeDiskObject(Icon);
  438.         }
  439.     }
  440.  
  441.     if(Handle = LT_CreateHandleTags(Window->WScreen,
  442.         LAHN_LocaleHook,    &LocaleHook,
  443.         LAHN_ExactClone,    TRUE,
  444.     TAG_DONE))
  445.     {
  446.         struct Window        *PanelWindow;
  447.         struct Region        *Clip = NULL,*Old;
  448.         struct Rectangle     ClipRect;
  449.         LONG                 ClipWidth,
  450.                              ClipHeight;
  451.  
  452.         if(!Ticks)
  453.         {
  454.             struct RastPort    This;
  455.             ULONG            Width,MaxWidth,Len,i;
  456.             STRPTR            String;
  457.  
  458.             InitRastPort(&This);
  459.             SetFont(&This,UserTextFont);
  460.  
  461.             for(i = MaxWidth = 0 ; Table[i] ; i++)
  462.             {
  463.                 Len = strlen(String = Table[i]);
  464.  
  465.                 if(*String == '\b' || *String == '\a')
  466.                 {
  467.                     ULONG Style;
  468.  
  469.                     if(*String == '\b')
  470.                         Style = FSF_BOLD;
  471.                     else
  472.                         Style = FSF_ITALIC;
  473.  
  474.                     SetSoftStyle(&This,Style,FSF_BOLD | FSF_ITALIC);
  475.                     String++;
  476.                     Len--;
  477.                 }
  478.                 else
  479.                     SetSoftStyle(&This,0,FSF_BOLD | FSF_ITALIC);
  480.  
  481.                 if(Len > 0)
  482.                 {
  483.                     Width = TextLength(&This,String,Len);
  484.  
  485.                     if(Width > MaxWidth)
  486.                         MaxWidth = Width;
  487.                 }
  488.             }
  489.  
  490.             ClipWidth    = MaxWidth;
  491.             ClipHeight    = HEADING * This.TxHeight;
  492.  
  493.             Clip = NewRegion();
  494.         }
  495.  
  496.         LT_New(Handle,
  497.             LA_Type,VERTICAL_KIND,
  498.         TAG_DONE);
  499.         {
  500.             LT_New(Handle,
  501.                 LA_Type,        VERTICAL_KIND,
  502.                 LA_LabelText,    TermName,
  503.             TAG_DONE);
  504.             {
  505.                 if(ImageBitMap)
  506.                 {
  507.                     LT_New(Handle,
  508.                         LA_Type,VERTICAL_KIND,
  509.                     TAG_DONE);
  510.                     {
  511.                         LT_New(Handle,
  512.                             LA_Type,            FRAME_KIND,
  513.                             LAFR_InnerWidth,    ImageWidth,
  514.                             LAFR_InnerHeight,    ImageHeight,
  515.                             LAFR_DrawBox,        FALSE,
  516.                             LA_ID,                GAD_FRAME,
  517.                         TAG_DONE);
  518.  
  519.                         LT_EndGroup(Handle);
  520.                     }
  521.                 }
  522.  
  523.                 LT_New(Handle,
  524.                     LA_Type,VERTICAL_KIND,
  525.                 TAG_DONE);
  526.                 {
  527.                     LT_New(Handle,
  528.                         LA_Type,        BOX_KIND,
  529.                         LABX_FirstLine,    MSG_TERMINFO_INFOTEXT1_TXT,
  530.                         LABX_LastLine,    MSG_TERMINFO_INFOTEXT2_TXT,
  531.                         LABX_AlignText,    ALIGNTEXT_Centered,
  532.                         LABX_DrawBox,    FALSE,
  533.                     TAG_DONE);
  534.  
  535.                     LT_EndGroup(Handle);
  536.                 }
  537.  
  538.                 if(!Ticks && Clip)
  539.                 {
  540.                     LT_New(Handle,
  541.                         LA_Type,VERTICAL_KIND,
  542.                     TAG_DONE);
  543.                     {
  544.                         LT_New(Handle,
  545.                             LA_Type,XBAR_KIND,
  546.                         TAG_DONE);
  547.  
  548.                         LT_New(Handle,
  549.                             LA_Type,            FRAME_KIND,
  550.                             LAFR_InnerWidth,    ClipWidth + 4,
  551.                             LAFR_InnerHeight,    ClipHeight + 2,
  552.                             LAFR_DrawBox,        FALSE,
  553.                             LA_ID,                GAD_SCROLL,
  554.                         TAG_DONE);
  555.  
  556.                         LT_EndGroup(Handle);
  557.                     }
  558.                 }
  559.  
  560.                 LT_EndGroup(Handle);
  561.             }
  562.  
  563.             LT_New(Handle,
  564.                 LA_Type,    VERTICAL_KIND,
  565.                 LA_LabelID,    MSG_V36_1030,
  566.             TAG_DONE);
  567.             {
  568.                 LT_New(Handle,
  569.                     LA_Type,VERTICAL_KIND,
  570.                 TAG_DONE);
  571.                 {
  572.                     LT_New(Handle,
  573.                         LA_Type,        BOX_KIND,
  574.                         LABX_FirstLine,    MSG_TERMINFO_INFOTEXT4_TXT,
  575.                         LABX_LastLine,    MSG_TERMINFO_INFOTEXT6_TXT,
  576.                         LABX_AlignText,    ALIGNTEXT_Centered,
  577.                         LABX_DrawBox,    FALSE,
  578.                     TAG_DONE);
  579.  
  580.                     LT_EndGroup(Handle);
  581.                 }
  582.  
  583.                 LT_New(Handle,
  584.                     LA_Type,    VERTICAL_KIND,
  585.                     LA_LabelID,    MSG_V36_1031,
  586.                 TAG_DONE);
  587.                 {
  588.                     LT_New(Handle,
  589.                         LA_Type,        BOX_KIND,
  590.                         LABX_FirstLine,    MSG_TERMINFO_INFOTEXT10_TXT,
  591.                         LABX_LastLine,    MSG_TERMINFO_INFOTEXT12_TXT,
  592.                         LABX_AlignText,    ALIGNTEXT_Centered,
  593.                         LABX_DrawBox,    FALSE,
  594.                     TAG_DONE);
  595.  
  596.                     LT_EndGroup(Handle);
  597.                 }
  598.  
  599.                 LT_New(Handle,
  600.                     LA_Type,    VERTICAL_KIND,
  601.                     LA_LabelID,    MSG_V36_1032,
  602.                 TAG_DONE);
  603.                 {
  604.                     LT_New(Handle,
  605.                         LA_Type,        BOX_KIND,
  606.                         LABX_FirstLine,    MSG_TERMINFO_INFOTEXT16_TXT,
  607.                         LABX_LastLine,    MSG_TERMINFO_INFOTEXT16_TXT,
  608.                         LABX_AlignText,    ALIGNTEXT_Centered,
  609.                         LABX_DrawBox,    FALSE,
  610.                     TAG_DONE);
  611.  
  612.                     LT_EndGroup(Handle);
  613.                 }
  614.  
  615.                 LT_EndGroup(Handle);
  616.             }
  617.  
  618.             if(!Ticks)
  619.             {
  620.                 LT_New(Handle,
  621.                     LA_Type,VERTICAL_KIND,
  622.                 TAG_DONE);
  623.                 {
  624.                     LT_New(Handle,
  625.                         LA_Type,        XBAR_KIND,
  626.                         LAXB_FullSize,    TRUE,
  627.                     TAG_DONE);
  628.  
  629.                     LT_New(Handle,
  630.                         LA_Type,        BUTTON_KIND,
  631.                         LA_LabelID,        MSG_V36_1033,
  632.                         LA_ID,            GAD_BUTTON,
  633.                         LABT_ReturnKey,    TRUE,
  634.                         LABT_ExtraFat,    TRUE,
  635.                     TAG_DONE);
  636.  
  637.                     LT_EndGroup(Handle);
  638.                 }
  639.             }
  640.  
  641.             LT_EndGroup(Handle);
  642.         }
  643.  
  644.         if(PanelWindow = LT_Build(Handle,
  645.             LAWN_IDCMP,        Ticks ? (IDCMP_RAWKEY | IDCMP_MOUSEMOVE | IDCMP_MOUSEBUTTONS | IDCMP_INTUITICKS) : (IDCMP_INTUITICKS),
  646.  
  647.             LAWN_HelpHook,    &GuideHook,
  648.             LAWN_MaxPen,    -1,
  649.             LAWN_Parent,    Window,
  650.             WA_RMBTrap,        TRUE,
  651.             WA_Activate,    TRUE,
  652.             WA_ReportMouse,    TRUE,
  653.  
  654.             Ticks ? TAG_DONE : TAG_IGNORE,0,
  655.  
  656.             WA_DepthGadget,    TRUE,
  657.             WA_DragBar,        TRUE,
  658.             LAWN_TitleID,    MSG_V36_1034,
  659.         TAG_DONE))
  660.         {
  661.             struct IntuiMessage    *Message;
  662.             BOOL                 Done = FALSE;
  663.             ULONG                 MsgClass,
  664.                                  MsgQualifier;
  665.             UWORD                 MsgCode;
  666.             struct Gadget        *MsgGadget;
  667.             ULONG                 Signals;
  668.             LONG                 TickCount = 0;
  669.             LONG                 Top,Total,LastLine,IntroTicks = 15;
  670.             struct RastPort        *RPort = PanelWindow->RPort;
  671.  
  672.             if(ImageBitMap)
  673.             {
  674.                 LONG LocalLeft,LocalTop;
  675.  
  676.                 LT_GetAttributes(Handle,GAD_FRAME,
  677.                     LA_Left,    &LocalLeft,
  678.                     LA_Top,        &LocalTop,
  679.                 TAG_DONE);
  680.  
  681.                 BltBitMapRastPort(ImageBitMap,0,0,RPort,LocalLeft,LocalTop,ImageWidth,ImageHeight,MINTERM_COPY);
  682.             }
  683.  
  684.             if(!Ticks)
  685.             {
  686.                 LONG LeftEdge,TopEdge;
  687.  
  688.                 LT_GetAttributes(Handle,GAD_SCROLL,
  689.                     LA_Left,    &LeftEdge,
  690.                     LA_Top,        &TopEdge,
  691.                 TAG_DONE);
  692.  
  693.                 ClipRect.MinX = LeftEdge + 2;
  694.                 ClipRect.MinY = TopEdge + 2;
  695.                 ClipRect.MaxX = LeftEdge + 2 + ClipWidth - 1;
  696.                 ClipRect.MaxY = TopEdge + 2 + ClipHeight - 1;
  697.  
  698.                 SetFont(RPort,UserTextFont);
  699.                 SetPens(RPort,Pens[TEXTPEN],Pens[BACKGROUNDPEN],JAM2);
  700.  
  701.                 if(OrRectRegion(Clip,&ClipRect))
  702.                 {
  703.                     LONG i;
  704.  
  705.                     Old = InstallClipRegion(PanelWindow->WLayer,Clip);
  706.  
  707.                     Top = ClipRect.MinY;
  708.  
  709.                     for(i = 0 ; i < HEADING ; i++)
  710.                     {
  711.                         PrintThisLine(RPort,&ClipRect,Top,Table[i]);
  712.  
  713.                         Top += RPort->TxHeight;
  714.                     }
  715.  
  716.                     LastLine = i;
  717.  
  718.                     Total = 0;
  719.                 }
  720.                 else
  721.                 {
  722.                     DisposeRegion(Clip);
  723.                     Clip = NULL;
  724.                 }
  725.             }
  726.  
  727.             while(Message = GT_GetIMsg(PanelWindow->UserPort))
  728.                 GT_ReplyIMsg(Message);
  729.  
  730.             if(!Ticks)
  731.                 PushWindow(PanelWindow);
  732.             else
  733.                 Say(LocaleString(MSG_TERMINFO_WELCOME_TO_TERM_TXT));
  734.  
  735.             do
  736.             {
  737.                 Signals = Wait(PORTMASK(PanelWindow->UserPort) | SIG_BREAK | SIG_REXX);
  738.  
  739.                 if(Signals & SIG_BREAK)
  740.                     break;
  741.  
  742.                 if(Ticks)
  743.                 {
  744.                     if(Signals & SIG_REXX)
  745.                     {
  746.                         GotRexxMessage = TRUE;
  747.  
  748.                         break;
  749.                     }
  750.                 }
  751.  
  752.                 while(Message = (struct IntuiMessage *)GT_GetIMsg(PanelWindow->UserPort))
  753.                 {
  754.                     MsgClass        = Message->Class;
  755.                     MsgQualifier    = Message->Qualifier;
  756.                     MsgCode            = Message->Code;
  757.                     MsgGadget        = (struct Gadget *)Message->IAddress;
  758.  
  759.                     GT_ReplyIMsg(Message);
  760.  
  761.                     if(Ticks)
  762.                     {
  763.                         if(MsgClass == IDCMP_INTUITICKS && TickCount++ >= 50)
  764.                             Done = TRUE;
  765.  
  766.                         if((MsgClass == IDCMP_RAWKEY || MsgClass == IDCMP_MOUSEBUTTONS) && !(MsgCode & IECODE_UP_PREFIX))
  767.                             Done = TRUE;
  768.  
  769.                         if(MsgClass == IDCMP_MOUSEMOVE)
  770.                             Done = TRUE;
  771.                     }
  772.                     else
  773.                     {
  774.                         LT_HandleInput(Handle,MsgQualifier,&MsgClass,&MsgCode,&MsgGadget);
  775.  
  776.                         if(MsgClass == IDCMP_GADGETUP)
  777.                             Done = TRUE;
  778.  
  779.                         if(MsgClass == IDCMP_INTUITICKS && Clip)
  780.                         {
  781.                             if(IntroTicks > 0)
  782.                                 IntroTicks--;
  783.                             else
  784.                             {
  785.                                 ScrollRaster(RPort,0,1,ClipRect.MinX,ClipRect.MinY,ClipRect.MaxX,ClipRect.MaxY);
  786.  
  787.                                 BeginRefresh(Handle->Window);
  788.                                 EndRefresh(Handle->Window,TRUE);
  789.  
  790.                                 Total++;
  791.  
  792.                                 PrintThisLine(RPort,&ClipRect,Top - Total,Table[LastLine]);
  793.  
  794.                                 if(Total == RPort->TxHeight)
  795.                                 {
  796.                                     Total = 0;
  797.  
  798.                                     LastLine++;
  799.  
  800.                                     if(!Table[LastLine])
  801.                                         LastLine = 0;
  802.                                 }
  803.                             }
  804.                         }
  805.                     }
  806.                 }
  807.             }
  808.             while(!Done);
  809.  
  810.             if(Clip)
  811.             {
  812.                 InstallClipRegion(PanelWindow->WLayer,Old);
  813.  
  814.                 DisposeRegion(Clip);
  815.             }
  816.  
  817.             if(!Ticks)
  818.                 PopWindow();
  819.         }
  820.  
  821.         LT_DeleteHandle(Handle);
  822.     }
  823.  
  824.     if(ImageBitMap)
  825.         LocalDeleteBitMap(ImageBitMap,ImageWidth,ImageHeight);
  826.  
  827.     return(GotRexxMessage);
  828. }
  829.